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(54) Data transmitting and/or receiving apparatus, methods and systems for preventint illegal 
use of data 



(57) Data to be transmitted via a serial bus (5) in 
conformity with the IEEE 1394 protocol are ciphered by 
a ciphering/deciphering circuit (24), and headers are at- 
tached thereto by a header sync detecting/generating 
circuit (23). After further attachment of a CRC code by 
a CRC detector/generator (33), the data are packetized 
into isochronous packets of an isochronous mode by a 
transmission/reception switching circuit (21), whereby 
transmission of the data can be performed with en- 



hanced security. Out of the cipher keys employed, a ses- 
sion key invariable in each session of the data is trans-- 
mitted in each packet of an asynchronous mode, and a 
time variable key updated in each session is transmitted 
in each packet of an isochronous mode. The ciphered 
data obtained by depacketizing the packets of the iso- 
chronous mode are deciphered, so that the data trans- 
mitted with security can be deciphered exactly, and thus 
illegal use of the data can be prevented. 



CM 
< 
CO 

o 

ID 
^* 

CO 

o 

GL 
LLI 



F I G. 2 



43 



42 



[video 
cassette 



REC/REP 
CIRCUIT 



12 < 



24 

< 



CIPHERING/ 

DECIPHERING 

CIRCUIT 



CIPHER/ 
DECIPHER 
CONTROL 
CIRCUIT 



— T- 

25 



41 



CPU 



23 



HEADER SYNC 

OET/GEN 

CIRCUIT 



22 -~ 



1 1--, PHY UNIT 



5-_ 



TRANS /REC 
SWITCHING 
CIRCUIT 



-2! 



31 



CYCLE TIMER 
| COUNTER | 



34 > 



32 



CYCLE MONITOR 



i REG 1 STER |[REG I STER 



36 



33 



35 



CRC DETECTOR 
/GENERATOR 



o 

o 



Printed by Jouve. 75001 PARIS (FR) 



1 EP 0 874 503 A2 



Description 

The present invention relates to a data transmitting 
apparatus and method, a data receiving apparatus and 
method, and a data transmitting/receiving system and 
method, and more particularly to those for preventing 
illegal use of data in transmitting and/or receiving the 
data. 

Recently, there has been widespread application of 
the IEEE 1394 high performance serial bus (hereinafter 
referred to simply as 1394 bus) standardized by the 
IEEE. In such 1394 bus, digital video and audio signals 
can be transmitted fast together with control commands 
in real time via a single cable by connecting thereto elec- 
tronic apparatus such as audio-visual (AV) apparatus 
and a personal computer. 

In transmission of data via a 1394 bus, there are 
known an asynchronous mode (asynchronous data 
transmission mode) and an isochronous mode (syn- 
chronous data transmission mode) where the data are 
synchronous with isochronous cycles of 8 kHz (1 25 u>s) 
generated by a cycle master in the 1394 bus. Com- 
mands are transmitted generally in an asynchronous 
mode, while video and audio signals are normally trans- 
mitted in an isochronous mode due to the necessity of 
real time reproduction. 

However, data transmission in the isochronous 
mode is performed through multi-address communica- 
tion where a destination of the data is not specified. For 
this reason, when any video or audio signal to be pro- 
tected with respect to the copyright is transmitted via a 
1 394 bus, there arises a problem in that some users not 
permitted by the relevant copyrighter may copy such 
video or audio signal illegally or may change or modify 
the copied signal. 

It is therefore an aim of at least an embodiment of 
the present invention to realize exact prevention of any 
illegal use of such data. 

According to a first aspect of the present invention, 
there is provided an apparatus for transmitting data in a 
first or asynchronous mode and a second or iso- 
chronous mode. This apparatus comprises a means for 
ciphering the data to be transmitted by the use of cipher 
keys; a means for packetizing the ciphered data into 
packets of the isochronous mode; and a means for 
transmitting the output of the packetizing means. In this 
apparatus, transmission of the data is performed in con- 
formity with the IEEE 1 394 protocol, and the packetizing 
means attaches, to a header of the ciphered data, an 
identification code relative to the ciphering. The cipher 
keys consist of a session key invariable in each session 
of the data to be transmitted, and a time variable key 
updated in each session. Information relative to the time 
variable key is contained in each packet of the iso- 
chronous mode, and information relative to the session 
key is also contained therein. 

According to a second aspect of the present inven- 
tion, there is provided a method of transmitting data in 



a first or asynchronous mode and a second or iso- 
chronous mode. This method comprises the steps of ci- 
phering the data to be transmitted by the use of cipher 
keys; packetizing the ciphered data into packets of the 
5 isochronous mode; and transmitting the packetized out- 
put. In this system, transmission of the data can be ex- 
ecuted with enhanced security. 

According to a third aspect of the present invention, 
there is provided an apparatus for receiving data trans- 
10 mitted thereto in a first or asynchronous mode and a 
second or isochronous mode. This apparatus compris- 
es a means for receiving the transmitted data; a means 
for depacketizing the output packets obtained from the 
receiving means; and a means for deciphering the ci- 
*5 phered data outputted from the depacketizing means. 
In this apparatus, transmission of the data is performed 
in conformity with the IEEE 1 394 protocol, and the de- 
packetizing means separates an identification code rel- 
ative to the ciphering from the received data. The cipher 
20 keys consist of a session key invariable in each session 
of the data to be transmitted, and a time variable key 
updated in each session. Information relative to the time 
variable key is contained in each packet of the iso- 
chronous mode, and information relative to the session 
25 key is also contained therein. Therefore, the data trans- 
mitted with security can be deciphered exactly. 

And according to a fourth aspect of the present in- 
vention, there is provided a method of receiving data 
transmitted in a first or asynchronous mode and a sec- 
30 ond or isochronous mode. This method comprises the 
steps of receiving the transmitted data; depacketizing 
the output packets obtained in the receiving step; and 
deciphering the ciphered data outputted in the depack- 
etizing step. 

35 Thus, it is possible to realize improvements in trans- 
mission and reception of the data with enhanced secu- 
rity. 

The invention will now be described by way of ex- 
ample with reference to the accompanying drawings, 
40 throughout which like parts are referred to by like refer- 
ences, and in which: 

Fig. 1 is a block diagram showing a structural ex- 
emple of a data transmitting/receiving system to 
45 which the present invention may be applied; 

Fig. 2 is a block diagram showing an internal struc- 
tural example of a digital video cassette recorder in 
Fig. 1; 

Fig. 3 is an explanatory diagram showing the timing 
so of data transmitted via a 1 394 bus; 

Fig. 4 shows a format of an isochronous packet; 
Fig. 5 shows a format of a CIP header; and 
Fig. 6 shows a format of a cycle start packet. 

55 Hereinafter some preferred embodiments of the 
present invention will be described in detail with refer- 
ence to the accompanying drawings. 

Fig. 1 shows a structural example of an information 
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processing system where the present invention is ap- 
plied. This system comprises a digital video cassette re- 
corder 1 . a television receiver 2, a personal computer 3 
and a DVD player 4 which are connected mutually via a 
1394 bus 5. 

Fig. 2 shows an internal structural example of the 
digital video cassette recorder 1 . A PHY unit 11 receives 
input data transmitted thereto via a 1 394 bus 5 and, after 
demodulating the same, outputs the demodulated data 
to a transmission/reception switching circuit 21 in a link 
unit 12. Further the PHY unit 11 demodulates data sup- 
plied from the transmission/reception switching circuit 
21 to be transmitted, and then outputs the modulated 
data to the 1 394 bus 5. 

The transmission/reception switching circuit 21 in 
the link unit 12 separates the input signal from the PHY 
unit 1 1 into packets of an asynchronous mode and pack- 
ets of an isochronous mode and, after depacketizing the 
asynchronous-mode packets, outputs the same to a 
CPU 41. Further the switching circuit 21 depacketizes 
the isochronous-mode packets and then outputs the 
same to a timing circuit 22. The asynchronous-mode 
signal supplied from the CPU 41 is packetized, while the 
data supplied from the timing circuit 22 are packetized 
into packets of the isochronous mode and then are out- 
putted to the PHY unit 11. 

The timing circuit 22 includes a cycle timer 31, a 
cycle monitor 32 and a CRC detector/generator 33. The 
cycle timer 31 has a counter 34 therein. The counter 34 
counts predetermined "clock pulses and generates a ~ 
count value which represents the timing of an iso- 
chronous cycle of 1 25 u^s. The cycle monitor 32 includes 
registers 35 and 36. In the register 35, there is held the 
destination offset value recorded in the cyc I e start pack" 
et transmitted via the 1394 bus. Meanwhile in the reg- 
ister 36, there is held the value of cycle time data of the 
cycle start packet. 

The CRC detector/generator 33 detects CRC data 
for error detection and correction from the received data, 
and then executes a process of error detection and cor- 
rection by the use of such CRC data. In transmission of 
the data, the CRC detector/generator 33 executes a 
process of attaching the CRC data to the data to be 
transmitted. 

At the data reception time, the header sync detect- 
ing/generating circuit 23 detects the header and the 
sync from the data supplied thereto from the timing cir- 
cuit 22 and, after separating the same, outputs the real 
data part to the ciphering/deciphering circuit 24. And at 
the data transmission time, the circuit 23 attaches the 
header and the sync to the data supplied to the cipher- 
ing/deciphering circuit 24 to be transmitted, and then 
outputs the same to the timing circuit 22. 

At the data reception time, the ciphering/decipher- 
ing circuit 24 deciphers the supplied data from the head- 
er sync detecting/generating circuit 23 under control of 
the cipher/decipher control circuit 25, and then outputs 
the deciphered data to the recording/reproducing circuit 



42. And at the data transmission time, the circuit 24 ci- 
phers the input data from the recording/reproducing cir- 
cuit 42 under control of the cipher/decipher control cir- 
cuit 25, and then outputs the ciphered data to the header 

5 sync detecting/generating circuit 23. The cipher/deci- 
pher control circuit 25 controls the header sync detect- 
ing/generating circuit 23 to attach predetermined iden- 
tification data to the header or the data, or to extract the 
same. Further the cipher/decipher control circuit 25 con- 

10 trols the operation of the ciphering/deciphering circuit 
24. 

At the data reception time, the recording/reproduc- 
ing circuit 42 modulates the input data from the cipher- 
ing/deciphering circuit 24 and then records the modu- 
is lated data in a video cassette 43. And in a reproduction 
mode, this circuit 42 reproduces the data recorded in 
the video cassette 43 and, after demodulating the repro- 
duced data, outputs the same to the ciphering/decipher- 
ing circuit 24. 

20 Fig. 3 shows the timing of data transmitted to the 
1394 bus 5. Suppose now that, for example, the digital 
video cassette recorder 1 reproduces the data from the 
video cassette 43 and transmits the reproduced data to 
the television receiver 2. It is also supposed here that 

25 the DVD player 4 transmits the data, which have been 
reproduced from a loaded DVD (disk), to the personal 
computer 3 via the 1 394 bus 5. In this example,. it is fur- 
ther supposed that a signal stream A is reproduced from 
the video cassette 43 and is outputted from the digital 

30~" videcfcassette recorder T, whilea signal St ream B is re- 
produced from the DVD and is outputted from the DVD 
player 4. 

Suppose now that the cycle master of the 1 394 bus 
— — 5 is the digital video cassette fecorder-1-for examplerln ~ 

35 this case, the CPU 41 controls the transmission/recep- 
tion switching circuit 21 to generate cycle start packets 
for specifying the 1 25 \is isochronous cycles of the 1 394 
bus 5. The cycle start packets are arrayed as S v S 2 , ... 
at the heads of isochronous cycles, as shown in Fig. 3. 

40 As will be described later with reference to Fig. 6, 
cycle time data are arrayed in the cycle start packet. The 
count value obtained from the counter 34 of the cycle 
timer 31 is recorded in the cycle time data. Any electron- 
ic apparatus other than the cycle master connected to 

45 the 1 394 bus 5 reads out the cycle time data and holds 
the same in the register of the internal cycle monitor. 

For example, when the cycle master is the personal 
computer 3 instead of the digital video cassette recorder 
1 , the personal computer 3 transmits cycle start packets. 

50 in this case, the digital video cassette recorder 1 re- 
ceives, in its PHY unit 11, the cycle start packet trans- 
mitted thereto via the 1 394 bus 5, and then depacketizes 
the received packet in its transmission/reception switch- 
ing circuit 21. Thereafter the depacketized data are in- 

55 putted to the timing circuit 22. Subsequently in the timing 
circuit 22,'the cycle time data contained in the cycle start 
packet are read out by the cycle monitor 32, and the 
read value is held in the register 36. And then, time man- 
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agement of the isochronous cycles on the 1394 bus 5 
is performed with reference to the value thus held in the 
register 36. 

In this manner, the time bases of isochronous cy- 
cles of the electronic apparatus connected to the 1 394 
bus 5 are rendered common. 

Since the digital video cassette recorder 1 and the 
DVD player 4 are currently transmitting data via the 
1 394 bus 5, time slots are allocated thereto at predeter- 
mined timing of each isochronous cycle in a manner to 
enable transmission of isochronous packets. Each of 
the digital video cassette recorder 1 and the DVD player 
4 compresses and packetizes the signal stream A or B, 
and then transmits the packetized data at the timing of 
the time slot allocated thereto. 

For example, the digital video cassette recorder 1 
reproduces the video cassette 43 in its recording/repro- 
ducing circuit 42, and then supplies the reproduced data 
to the ciphering/deciphering circuit 24 for ciphering the 
data by the use of cipher keys which consist of a session 
key S and a time variable key i. The ciphered data are 
supplied to the header sync detecting/generating circuit 
23, where the data are compressed and a header is at- 
tached thereto. The header-attached data thus obtained 
are inputted to the timing circuit 22, where a CRC code 
is further attached to each of the header and the data 
part.' 

The data outputted from the timing circuit 22 are 
supplied to the transmission/reception switching circuit 
21 and then are packetized into a packet of the iso- 
chronous mode. As described, this packet is transmitted 
from the PHY unit 11 via the 1394 bus 5 at the timing of 
the allocated time slot. . 

Such a process is executed per isochronous cycle 
as shown in Fig. 3, and signals A v A 2 , A 3 , ... of a signal 
stream A are transmitted as packets, which are denoted 
by the same reference symbol, at the timing of prede- 
termined time slots of individual isochronous cycles. In 
any isochronous cycle where none of data to be trans- 
mitted is existent, empty packets a 1( a 2 are transmitted. 
In each empty packet, merely a header is existent with- 
out any real data part. 

An operation similar to the above is performed in 
the DVD player 4 also, so that signals B*,, B 2 , ... of a 
signal stream B are transmitted as packets, which are 
denoted by the same reference symbol, at the timing 
different from the signal stream A. 

For example, when the CPU 41 transmits a com- 
mand, the command is inputted to the transmission/re- 
ception switching circuit 21. Then this circuit 21 pack- 
etizes the command into a packet of the asynchronous 
mode and transmits the same as C-,, C 2 or the like, as 
shown in Fig. 3. 

Such asynchronous packet is transmitted in accord- 
ance with requirement, and is not generated always in 
each isochronous cycle. 

Similarly, as will be described later, the CPU 41 
transmits a session key S, which is one of cipher keys, 



in an asynchronous packet. 

In this manner, the signal stream A transmitted via 
the 1 394 bus 5 is received by the television receiver 2, 
while the signal stream B is received by the personal 

s computer 3. Suppose now that, for the sake of explan- 
atory convenience, the signal stream A is received by 
the digital video cassette recorder 1 shown in Fig. 2. In 
this case, the following operation is performed. 

The PHY unit 11 receives the packets transmitted 

10 thereto via the 1 394 bus 5 and then supplies the same 
to the transmission/reception switching circuit 21 . Sub- 
sequently, this switching circuit 21 separates the input 
packets into isochronous packets and asynchronous 
packets, then depacketizes the isochronous packets 

1$ and outputs the data to the timing circuit 22. The circuit 

21 depacketizes the asynchronous packets also and 
outputs the data to the CPU 41 . As a result, for example, 
the signal stream A is supplied to the timing circuit 22, 
while the command and the session key S are supplied 

20 to the CPU 41. 

The CRC detector/generator 33 in the timing circuit 

22 supplies the input data to the header sync detecting/ 
generating circuit 23. Subsequently the CRC detector/ 
generator 33 detects the CRC code from the data sup- 

25 p|jed thereto from the header sync detecting/generating 
circuit 23, and then executes a process of error detec- 
tion and correction by the use of such CRC code. There- 
after the error-corrected data are returned to the header 
- sync detecting/generating circuit 23 - — ■ - - 

30 The header sync detecting/generating circuit 23 
separates the header from the input data and supplies 
the header information to the cipher/deciphercontrol cir- 

. _ cuit 25 while supplying the real data part to the ciphering/- 
deciphering circuit 24. The cipher/decipher control cir- 

35 cuit 25 detects ciphering identification data included in 
the header detected by the header sync detecting/gen- 
erating circuit 23, and then controls the ciphering/deci- 
phering circuit 24 in accordance- with the result of such 
detection. More specifically, when the identification data 

40 signifies that the data are ciphered, the control circuit 25 
enables the ciphering/deciphering circuit 24 to execute 
a deciphering process by the use of the cipher key But 
when the identification data signifies that the data are 
not ciphered, such deciphering process is omitted. 

45 The data outputted from the ciphering/deciphering 
circuit 24 are modulated in a predetermined mode by 
the recording/reproducing circuit 42 and then are sup- 
plied to the video cassette 43 to be recorded therein. 
In the embodiment of this invention, cipher keys em- 

50 ployed for ciphering and deciphering the data in the ci- 
phering/deciphering circuit 24 consist of a session key 
S and a time variable key i. The session key S is updated 
per session (e.g., per movie information or per repro- 
duction). In other words, the session key S has an in- 

55 variable value within one session, whereas the time var- 
iable key i is updated frequently in each session. Thus, 
higher security can be achieved by the use of a session 
key S and a time variable key i as cipher keys. 
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More specifically, even if the session key S is pirat- 
ed, it is impossible to decipher the ciphered data in case 
the time variable key i is unknown. Further, even if the 
time variable key i is also pirated, since the time variable 
key i is updated every moment, the data are decipher- 
able merely for an extremely short period of time but are 
rendered not decipherable any longer thereafter. 

The session key S is transmitted at predetermined 
timing in an asynchronous packet, as denoted by K v K 2 
in Fig. 3. However, as will be described later, it is a matter 
of course that the session key S can be transmitted in 
an isochronous packet similarly to the time variable key 
i. 

Fig. .4 shows a format of an isochronous packet. As 
represented in this diagram, first two quadlets are used 
as an isochronous header. A data length is recorded at 
the top of this header, and next is recorded a tag which 
indicates whether a C1P header is attached or not in a 
data field. Thereafter a channel is disposed next to the 
tag. This channel is used to identify, for example, a 
stream A or a stream B in Fig. 3. 

In Fig. 4, "tcode" (transaction code) prescribes the 
format of a packet. In the case of an isochronous start 
packet, it is set to 1010 (= A). Next "sy" denotes a syn- 
chronization code which is prescribed per application. 
In the embodiment of this invention, two bits of the time 
variable key i composed of 32 to 40 bits are disposed in 
the two lower-order bits of the synchronization code 
*sy". For example, when the time variable key i is com- 
posed of 32 bits, a total of 16 packets completely con- 
stitute the time variable key i. A flag, which signifies that 
the relevant packet is the top one or not of the time var- 
iable key i, can be attached to the third bit from the LSB 
of the code "sy". For example7this-third bit is -.seUo-Un- 
case the relevant packet is the top one of the time var- 
iable key i, or it is set to 0 in the other case. 

when the time variable key i is recorded as de- 
scribed in the synchronization code "sy", a value 1100 
(= C) may be set in "tcode" to serve as an identification 
code of the time variable key L 

The cipher/decipher control circuit 25 collects two 
bits of the time variable key i in each packet from the 
header information outputted from the header sync de- 
tecting/generating circuit 23 and, upon termination of 
collecting such bits of 16 packets, transfers the complet- 
ed time variable key i to the ciphering/deciphering circuit 
24. 

As shown in Fig. 4, the second quadlet of the iso- 
chronous header is used as a header CRC. And a CIP 
header corresponding to two quadlets is disposed in the 
next data field of the isochronous header, and contents 
are disposed thereafter. The contents represent ci- 
phered data, as described above. 

According to the MPEG standard, a source header 
is disposed in the area of such contents. In this case, 
any source header with a time stamp or the like recorded 
therein is not ciphered. 

Data CRC is disposed next to the data field. 



Fig. 5 shows a detailed structure of a CIP header. 
As represented in this diagram, a bit (= 0) signifying the 
top of the header is disposed at the top thereof in the 
first CIP header 1 out of headers of two quadlets, while 

s a bit 1 is disposed in the second CIP header 2. More 
specifically, the first bit serves as "EOH_n" (End of CIP 
header) signifying whether this quadlet is the last or not 
of the CIP header. This value is set to 0 when any other 
quadlet follows, or to 1 when it is the last quadlet of the 

10 CIP header. 

The second bit serves as "Form_n" which repre- 
sents, in combination with "EOH", the quadlet of the CIP 
header field. In the embodiment of the present invention, 
this bit is set to 1 in the case of ciphered data, or to 0 in 

is the case of non-ciphered data. 

The third to eighth bits of the CIP header 1 serve as 
"SID" (Source node ID), and "DBS" (Data block size in 
quadlets) is disposed next to "SID". This "DBS" repre- 
sents the block size of the data. And "FN" (Fraction 

20 number) disposed next represents the number of blocks 
into which one source packet is divided. Next "QPC" 
(Quadlet padding count) represents the number of dum- 
my quadlets attached. And "SPIT (Source packet head- 
er) disposed next signifies whether the source packet 

25 has a source packet header or not. 

An area "Rsv" is reserved for the future, and "DBC° 
represents the counts value of successive data blocks 
for detecting the data block loss. 

"FMT" represents a Format ID, and "FDF" repre- 
ss - sents a Format dependent field." ~~ " 

Fig. 6 shows a format of a cycle start packet. At the 
top of this packet, there is disposed "destnationJD" 
which represents ID of a data destination. Each bit of 
-_=next-J!tl" (transaction-label)-is set normally- to O.-And the - 

35 value of the time variable key i for example can be re- 
corded here. 

Each bit of "rt" (retry code) is set normally to 0. And 
a packet type transaction code is disposed in next 
"tcode" (transaction code). 

40 An area "pri" stands for priority, and each bit thereof 
is set to 1 when used between apparatus connected mu- 
tually via the 1 394 bus 5. The time variable key i can be 
allocated to this "pri" also. 

ID of a data source is recorded in "sourceJD", and 

45 a clock value corresponding to the timing deviation from 
the cycle start packet is set in "destination_offset". And 
a register value used as a reference for the cycle master 
as described is set in "cycle_time_data". The time base 
reference of the isochronous cycle of each electronic 

so apparatus connected to the 1394 bus 5 is set with ref- 
erence to this clock value. Also the CRC of the header 
is disposed in the last area. 

In the embodiment described above, the time vari- 
able key i is transmitted after being written in the data 

55 part or the header of each packet. However, the value 
of "destination_offset", "cycle_time_data" or 
"header_CRC" in the cycle start packet may be used 
directly as the time variable key i. 
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Since each electronic apparatus reads out such val- 
ues and holds the same in the registers 35 and 36 of the 
cycle monitor 32, it is also possible to extract the time 
variable key i from the values thus held. 

Further, the value of "DBC" of the CiP header shown 
in Fig. 5 or the value of "data_CRC" shown in Fig. 4 may 
be used directly as the time variable key i. 

Thus, according to the data transmitting apparatus 
and method embodying the present invention, ciphered 
data are packetized into packets of an isochronous 
mode and then are transmitted to a serial bus, whereby 
data transmission can be performed with enhanced se- 
curity. 

According to the data receiving apparatus and 
method embodying the invention, ciphered data ob- 
tained by depacketizing the packets of the isochronous 
mode are deciphered, so that the data transmitted with 
security can be deciphered exactly. 

The data ciphered by the data transmitting appara- 
tus are transmitted after being packetized into packets 
of the isochronous mode and are received by the data 
receiving apparatus. Consequently, it becomes possible 
to realize an improved data transmitting/receiving sys- 
tem in which enhanced security is achieved. 

Although the present invention has been described 
hereinabove with reference to some preferred embodi- 
ments thereof, it is to be understood that the invention 
is not limited to such embodiments alone, and a variety 
of other changes and modifications will be apparent to 
those skilled in the art without departing from the scope 
of the invention as claimed. 



Claims 

1. An apparatus for transmitting data in a first mode 
and a second mode, comprising; 

a means for ciphering the data to be transmitted 

by the use of cipher keys; 

a means for packetizing the ciphered data into 

packets of the second mode; and 

a means for transmitting the output of said 

packetizing means. 

2. The apparatus according to claim 1 , wherein trans- 
mission of the data is performed in conformity with 
the IEEE 1394 protocol. 

3. The apparatus according to claim 1, wherein said 
first mode is an asynchronous mode, and said sec- 
ond mode is an isochronous mode. 

4. The apparatus according to claim 3, wherein said 
packetizing means attaches, to a header of the ci- 
phered data, an identification code relative to the 
ciphering. 



5. The apparatus according to claim 3, wherein said 
cipher keys consist of a session key invariable in 
each session of the data to be transmitted, and a 
time variable key updated in each session. 

s 

6. The apparatus according to claim 5, wherein infor- 
mation relative to the time variable key is contained 
in each packet of the isochronous mode. 

10 7. The apparatus according to claim 6, wherein the in- 
formation relative to the time variable key is con- 
tained in a start packet of the isochronous mode. 

8. The apparatus according to claim 5, wherein infor- 
ms mation relative to the session key is contained in 

each packet of the isochronous mode. 

9. The apparatus according to claim 6, wherein the in- 
formation relative to the session key is contained in 

20 a start packet of the isochronous mode. 

10. A method of transmitting data in a first mode and a 
second mode, comprising the steps of: 

25 ciphering the data to be transmitted by the use 

of cipher keys; 

packetizing the ciphered data into packets of 
the second mode; and 
transmitting the packetized output. 

30 

11. The method according to claim 10, wherein trans- 
mission of the data is performed in conformity with 
the IEEE 1394 protocol. 

35 12. The method according to claim 10, wherein said first 
mode is an asynchronous mode, and said second 
mode is an isochronous mode. 

13. The method according to claim 1 2, wherein an iden- 
40 tification code relative to the:ciphering is attached, 

in said packetizing step, to a header of the ciphered 
data. 

14. The method according to claim 12, wherein said ci- 
45 pher keys consist of a session key invariable in each 

session of the data to be transmitted, and a time 
variable key updated in each session. 

15. The method according to claim 14, wherein infor- 
50 mation relative to the time variable key is contained 

in each packet of the isochronous mode. 

16. The method according to claim 15, wherein the in- 
formation relative to the time variable key is con- 

55 tained in a start packet of the isochronous mode. 

17. The method according to claim 14, wherein infor- 
mation relative to the session key is contained in 
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each packet of the isochronous mode. 

18. The method according to claim 15, wherein the in- 
formation relative to the session key is contained in 
a start packet of the isochronous mode. 

19. An apparatus for receiving data transmitted thereto 
in a first mode and a second mode, comprising: 

a means for receiving the transmitted data; 
a means for depacketizing the output packets 
obtained from said receiving means; and 
a means for deciphering the ciphered data out- 
putted from said depacketizing means. 

20. The apparatus according to claim 19, wherein 
transmission of the data is performed in conformity 
with the IEEE 1394 protocol. 

21 . The apparatus according to claim 1 9, wherein said 
first mode is an asynchronous mode, and said sec- 
ond mode is an isochronous mode. 

22. The apparatus according to claim 21, wherein said 
depacketizing means separates an identification 
code relative to the ciphering from the received da- 
ta. 

23. The apparatus according to claim 21 , wherein said 
cipher keys consist of a session key invariable in" 
each session of the data to be transmitted, and a 
time variable key updated in each session. 
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29. The method according to claim 28, wherein trans- 
mission of the data is performed in conformity with 
the IEEE 1394 protocol. 

30. The method according to claim 28, wherein said first 
mode is an asynchronous mode, and said second 
mode is an isochronous mode. 

31 . The method according to claim 30, wherein an iden- 
tification code relative to the ciphering is separated 
from the received data in said depacketizing step. 

32. The method according to claim 30, wherein said ci- 
pher keys consist of a session key invariable in each 
session of the data, and a time variable key updated 
in each session. 



20 



25 



33. 



34. 



35. 



The method according to claim 32, wherein infor- 
mation relative to the time variable key is contained 
in each packet of the isochronous mode. 

The method according to claim 33, wherein the in- 
formation relative to the time variable key is con- 
tained in a start packet of the isochronous mode. 

The method according to claim 32, wherein infor- 
mation relative to the session key is contained in 
each packet of the isochronous mode. 



~30 ~^36rfhe method accordingto claim 33, wherein the in- 
formation relative to the session key is contained in 
a start packet of the isochronous mode. 



24. -The apparatus according to claim 23r-wherein infor^=^-- 

mation relative to the time variable key is contained 35 
in each packet of the isochronous mode. 

25. The apparatus according to claim 24, wherein the 
information relative to the time variable key is con- 
tained in a start packet of the isochronous mode. *o 

26. The apparatus according to claim 23, wherein infor- 
mation relative to the session key is contained in 
each packet of the isochronous mode. 

45 

27. The apparatus according to claim 24, wherein the 
information relative to the session key is contained 
in a start packet of the isochronous mode. 

28. A method of receiving data transmitted in a first so 
mode and a second mode, comprising the steps of: 

receiving the transmitted data; 
depacketizing the output packets obtained in 
said receiving step; and 55 
deciphering the ciphered data outputted in said 
depacketizing step. 
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mitted in each packet of an asynchronous mode, and a 
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in each packet of an isochronous mode. The ciphered 
data obtained by depacketizing the packets of the iso- 
chronous mode are deciphered, so that the data trans- 
mitted with security can be deciphered exactly, and thus 
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